<!-- 我的查询 -->

<template>
  <WebSearch :onSearch="changeRange">
    <template #btn>
      <ParamTab />
      <BtnDownload @click="toExport" />
    </template>

    <ParamDateRange bind="startTime, endTime" history noClear @change="changeRange" />
  </WebSearch>
</template>

<script>
// ============================== 导入依赖 ============================== //

import CORE from '@/CORE'
import OurSearch from '@admin/views/Maintain/Report/ReportWork/components/OurSearch'

// ============================== 导出组件 ============================== //

export default {
  /**
   * 名称定义 (实际使用名称)
   */
  name: 'MySearch',

  /**
   * 混入列表 (配置选项合并)
   */
  mixins: [
    CORE.mixWeb(),
    CORE.mixWeb('summary', 'summary_'),
    CORE.mixWeb('detail', 'detail_'),
    CORE.mixLoad(),
  ],

  /**
   * 监听属性 (深度 deep 首次 immediate)
   */
  watch: {
    /**
     * 监听部门 ID
     */
    'param.deptId'() {
      this.toSearch()
    },
  },

  /**
   * 创建完成 (先抽取再调用)
   */
  created: OurSearch.created,

  /**
   * 本地方法 (轻量重要在前)
   */
  methods: {
    ...OurSearch.methods,

    /**
     * 查询
     */
    toSearch() {
      const { deptId, startTime, endTime } = this.param
      CORE.merge(this.summary_param, { deptId, startTime, endTime })
      this.summary_startList(1)

      CORE.merge(this.detail_param, { deptId, begin: startTime, end: endTime })
      this.detail_startList(1)
    },

    /**
     * 导出
     */
    toExport() {
      this.startDownload()
    },
  },
}
</script>
